|
In computability theory, the T predicate, first studied by mathematician Stephen Cole Kleene, is a particular set of triples of natural numbers that is used to represent computable functions within formal theories of arithmetic. Informally, the ''T'' predicate tells whether a particular computer program will halt when run with a particular input, and the corresponding ''U'' function is used to obtain the results of the computation if the program does halt. As with the smn theorem, the original notation used by Kleene has become standard terminology for the concept.〔The predicate described here was presented in (Kleene 1943) and (Kleene 1952), and this is what is usually called "Kleene's ''T'' predicate". (Kleene 1967) uses the letter ''T'' to describe a different predicate related to computable functions, but which cannot be used to obtain Kleene's normal form theorem.〕 == Definition == The definition depends on a suitable Gödel numbering that assigns natural numbers to computable functions. This numbering must be sufficiently effective that, given an index of a computable function and an input to the function, it is possible to effectively simulate the computation of the function on that input. The ''T'' predicate is obtained by formalizing this simulation. The ternary relation ''T''1(''e'',''i'',''x'') takes three natural numbers as arguments. The triples of numbers (''e'',''i'',''x'') that belong to the relation (the ones for which ''T''1(''e'',''i'',''x'') is true) are defined to be exactly the triples in which ''x'' encodes a computation history of the computable function with index ''e'' when run with input ''i'', and the program halts as the last step of this computation history. That is, ''T''1 first asks whether ''x'' is the Gödel number of a finite sequence 〈''x''''j''〉 of complete configurations of the Turing machine with index ''e'', running a computation on input ''i''. If so, ''T''1 then asks if this sequence begins with the starting state of the computation and each successive element of the sequence corresponds to a single step of the Turing machine. If it does, ''T''1 finally asks whether the sequence 〈''x''''j''〉 ends with the machine in a halting state. If all three of these questions have a positive answer, then ''T''1(''e'',''i'',''x'') holds (is true). Otherwise, ''T''1(''e'',''i'',''x'') does not hold (is false). There is a corresponding function ''U'' such that if ''T''(''e'',''i'',''x'') holds then ''U''(''x'') returns the output of the function with index ''e'' on input ''i''. Because Kleene's formalism attaches a number of inputs to each function, the predicate ''T''1 can only be used for functions that take one input. There are additional predicates for functions with multiple inputs; the relation :, holds if ''x'' encodes a halting computation of the function with index ''e'' on the inputs ''i''1,...,''i''''k''. 抄文引用元・出典: フリー百科事典『 ウィキペディア(Wikipedia)』 ■ウィキペディアで「Kleene's T predicate」の詳細全文を読む スポンサード リンク
|